<template>
  <el-card class='box-card'>
    <div slot='header' class='clearfix'>
      <span>基本资料</span>
    </div>
    <!-- 表单 -->
    <el-form
      :model='userForm'
      :rules='userFormRules'
      ref='userFormRef'
      label-width='100px'
    >
      <el-form-item label='登录名称' prop='username'>
        <el-input v-model='userForm.username' disabled></el-input>
      </el-form-item>
      <el-form-item label='用户昵称' prop='nickname'>
        <el-input
          v-model='userForm.nickname'
          minlength='1'
          maxlength='10'
        ></el-input>
      </el-form-item>
      <el-form-item label='用户邮箱' prop='email'>
        <el-input v-model='userForm.email'></el-input>
      </el-form-item>
      <el-form-item>
        <el-button type='primary' @click='submitFn'>提交修改</el-button>
        <el-button @click="restFn">重置</el-button>
      </el-form-item>
    </el-form>
  </el-card>
</template>
<script>
import { upDateuserInfo } from '@/api/index'
export default {
  name: 'UserInfo',
  data () {
    return {
      userForm: {
        username: this.$store.state.userinfo.username, // 默认值用登录后获取到的用户名
        nickname: '',
        email: ''
      },
      // 表单的验证规则对象
      userFormRules: {
        nickname: [
          { required: true, message: '请输入用户昵称', trigger: 'blur' },
          {
            pattern: /^\S{1,10}$/,
            message: '昵称必须是1-10位的非空字符串',
            trigger: 'blur'
          }
        ],
        email: [
          { required: true, message: '请输入用户邮箱', trigger: 'blur' },
          { type: 'email', message: '邮箱格式不正确', trigger: 'blur' }
        ]
      }
    }
  },
  methods: {
    submitFn () {
      this.$refs.userFormRef.validate(async res => {
        if (res) {
          this.userForm.id = this.$store.state.userinfo.id
          const { data: res } = await upDateuserInfo(this.userForm)
          if (res.code !== 0) this.$message.error('更新错误')
          this.$message.success('更新成功')
          this.$store.dispatch('getUserInfoAction')
          console.log(res)
        } else { return false }
      })
    },
    restFn () {
      // this.userForm.nickname = ''
      // this.userForm.email = ''
      this.$refs.userFormRef.resetFields()
    }
  }
}
</script>

<style lang='less' scoped>
.el-form {
  width: 500px;
}
</style>
